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CONTEXT BASED VIEW DESIGN TO SUPPORT CLIENT SIDE 

MULTI-THREADING 

5 

Field of the invention 

10 The invention relates to the field of computer software and software design, particularly 
but not solely the design and development of Object Oriented multi-threaded GUI-based 
client applications. 

Background of the invention 

15 

One of the most common models currently used for implementing client applications 
involves dividing the essential elements of the tasks to be performed by the application 
among three types of objects, for example View objects, Handler objects and Business 
Logic objects. 

20 

Figure 1 shows the typical inter-relationships between these three sub-systems. 

A View object 10 is responsible for presentation details of the User Interface (UI) which 
is generally a Graphical User Interface (GUI). A controller or handler object 20 is 
25 responsible for managing the execution and co-ordination aspects of a task. Finally a 
Business logic object 30 is responsible for the business data and business logic aspects of 
a task. 

The application can be thought of as being made up of one or more use cases or tasks. A 
30 use case may be for example finding a list of customers satisfying a given search criterion 
or may be changing customer details. 

Each use case is captured as a handler 20 which is responsible for coordinating and 
controlling the sequence of actions that need to be performed to implement the use case. 
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Once the application identifies the use case, it creates an appropriate handler and passes 
control to it. In fact the application itself could be thought of as a handler. 

The handler 20 must create the appropriate views for the use case and respond to any 
5 events in them. 

The view essentially presents the data or business object but in theory is not concerned 
with the business logic (which operations are to be performed on that data or what it is 
for). The view is usually made up of GUI components through which the user can receive 
10 appropriate input cues and output information, for example data display fields, data entry 
fields, menus and buttons. It is the view object or sub-system that the user interacts with. 
The user may enter some data, for example, and press a button. 

The handler, which is always "listening" to the view for relevant events, would then be 
15 notified that the user has requested some action to be performed and pass the data and 
instructions for this action to the appropriate Business Logic object. 

A Business Logic Object 30 carries out the business logic for the use case. The handler 
20 must create appropriate business logic object peers for the use case and invoke the 
20 appropriate methods in them. 

The View and Business Logic objects can communicate directly to ascertain when the 
View should refresh itself, or their communication can be coordinated by the handler. 
The View then refreshes itself from the updated data provided by the Business Logic 
25 Object and the user is presented with the results of their request. 

It will be appreciated that in a typical client GUI application a given view may participate 
in more than one use case. Creating a view per use case may not be a good solution as it 
is expensive in terms of memory and resources. It would be useful to have a model in 
30 which the view could be reused over all the use cases for which it is relevant. 
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In addition the complex interrelationships between the view, handler and business object 
model mean that data flow becomes much more complicated in a multi-threaded 
environment. It would also be useful to have a model in which data could be more easily 
transferred and persisted within each use case, even in a multi-threaded environment. 

5 

Summary of Invention 

In broad terms in one form there is provided a computer software system comprising a 
10 view sub-system including presentation objects which provide a user interface; a business 
logic sub-system including business object implementation objects which hold business 
data and implement business logic; a handler sub-system including controller objects 
which control the sequence of actions in a use case; and a view context sub-system 
including context objects which capture input/output data. 

15 

In broad terms in another form there is provided a computer program comprising at least 
one view object including presentation objects which provide a user interface; at least one 
business logic object which holds business data objects and implements business 
functions; at least one handler object which controls the actions of at least one of the view 
20 objects and at least one of the business logic objects; and at least one view context object 
including data objects which capture the state of at least one of the view objects. 

In broad terms in another form there is provided a method of passing data in an object 
oriented application having at least one handler object, the method comprising the steps 
25 of creating a view object with the handler object; creating a view context object with the 
view object; passing the view context to the handler object; updating the view context 
with the handler object; and refreshing the view object from the view context. 

Brief Description of the Drawings 

30 

Preferred forms of the invention will now be described with reference to the 
accompanying figures in which: 
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Figure 1 shows a prior art client application model divided into view, handler and 
business objects; 

Figure 2 shows an arrangement of typical computer equipment that could be used in 
connection with the invention; 
5 Figure 3 shows a block diagram of a computer network arrangement; 

Figure 4 shows a block diagram of the interaction between view, handler and view 
context objects; 

Figure 5 is a flow diagram of a generic use case using a view context object; 
Figure 6 shows an exemplary method of passing view context data; 
10 Figure 7 shows a simple block diagram of a use case which uses more than one handler; 
Figure 8 is a block diagram of the flow of an example use case with more than one view 
and more than one handler; and 

Figure 9 is a chart of the flow of an example use case with more than one view and more 
than one handler. 

15 

Detailed Description of Preferred Forms 

Figure 2 shows a preferred system architecture for the invention. The computer system 40 
typically comprises a central processor 50, a main memory 60 for example RAM, and an 

20 input/output controller 70. The computer system 40 also comprises peripherals such as a 
keyboard 80, a pointing device 90 for example a mouse, touch pad or track ball, a display 
or screen device 100, a mass storage memory 110 for example a hard disk, floppy disk or 
optical disc, and an output device 120 for example a printer. The system 40 may also 
include a network interface card or controller 130 and/or a modem 140. The individual 

25 components of the system 40 may communicate through a system bus 150. 
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Preferably the invention is implemented on a computer running an operating system with 
a Graphical User Interface such as OS/2, Mac OS or Microsoft Windows. 

Components 50, 60, 70, 80, 90, 100, 120, 130, 140 and 150 may be set up as a stand- 
5 alone computer or may be connected to further components in a network. The invention 
may be implemented on such a stand-alone machine or may be distributed across a 
network. 

Figure 3 shows a preferred network set-up for the invention. Client systems may run on 
10 various clients, for example 160A, 160B, 160C, 160D, 160E and 160F, which each may 
comprise a personal computer or workstation described above. Each client is interfaced to 
a server machine 250. Each client 160 may be connected directly to the server, may be 
connected through a local area network or LAN or may be connected through the 
Internet. Any combination of wire or wireless networks may be used. 

15 

Clients 160A and 160B for example, are connected to a network 170, such as a local area 
network or LAN. The network 170 may be connected to a suitable network server and 
communicate with the server machine as shown. Client 160C is shown connected directly 
to the server. Clients 160D, 160E and 160F are shown connected to the server through 
20 the Internet 190. Client 160D is shown as connected to the Internet 190 with a dial-up 
connection and clients 160E and 160F are shown connected to a network 200 such as a 
local area network or LAN, with the network 200 connected to a suitable network server 
210. 

25 Preferably the invention is implemented using an Object Oriented programming 
language, for example the Java programming language, although any appropriate object 
oriented programming language may used. 

The invention uses the currently popular division of essential use case elements into 
30 views, controllers and business objects as illustrated in Figure 1; however, the invention 
provides a model which has been modified to include a new type of object. 



JP920000314US1 



6 



Figure 4 shows the interaction of view and handler objects according to the invention. As 
is usual, a view 400 is designed with the basic user interface (UI) components embedded 
in it. However in this invention the data used for populating the view is not captured as 
5 part of the view itself. These data objects 410 are encapsulated in a new type of object 
called a view context object 420. 

The view context object 420 is a context object, which comes into existence at the time of 
the creation of a view 400. The view context object 420 comprises all the data that the 
10 view displays or takes as input. The view presents the data from the view context object 
420 when it is refreshed with the view context. Given a totally new view context, the 
view would present different information. 

The view context object 420 is typically made up of the data object interfaces for the 
15 various business objects. This means that once the handler 430 has invoked the 
appropriate business logic for a use case, the view context object 420 can be 
automatically populated with the new data which returns from the server. 

A given view instance understands the make up of a view context and can address the 
20 individual elements discretely, getting and setting data objects as required. 

For example, a user may enter some data for a query. The view 400 will set the data 
objects in the view context with the appropriate data. When an event is triggered from 
the view 400 such as the OK button being pressed, the View associates the event with the 
25 view context object 420 and passes the view context to the handler. The handler 430 now 
initiates business method calls in response to the event and the view context object 420 is 
updated accordingly. The handler then passes the updated view context object 420 back 
to the view 400 with instructions to refresh itself with the view context object 420. 

30 The event which the view associates with the view context contains action information 
which governs the behavior of the view once the view context object 420 is populated 
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with the result data. This is necessary because different user requests may require 
different behavior from the view. For example, a drag and drop event may result in a 
specific behavior by the view while a button pressed event might require a different 
response. When the view associates an event with its view context it is therefore 
5 predetermining its future actions because when the handler passes back the updated view 
context the view will refresh itself by executing the action part of the event that it 
originally associated with the view context. 

In this way both the data for populating a view and certain behaviors of the view are 
10 abstracted away from the view itself. 

Figure 4 illustrates how the GUI and business logic areas of the application remain 
distinct. Through the use of the view context the data objects for the use case are made 
accessible to both the GUI and business logic but the division of labor remains well 
15 defined. The ability to pass the view's context around also means there is no state that 
needs to be maintained by either the view or the handler of the use case. 

Figure 5 shows a flow chart for a possible use case. The handler creates the view at 502. 
The view in turn creates the view context at 503. The view now enters into its event- 

20 processing loop waiting for instructions from the user. When an event is triggered at 504, 
the view passes the view context and the associated event to the handler with the 
appropriate data values set at 505 and the handler must see to the processing of the user 
request. The handler therefore updates the view context as required at 506 and then 
instructs the view to refresh itself to display the results at 507. The view refreshes itself 

25 from the view context at 508 . The view refreshes itself according to the action 
information from the event which was associated with the view context at 504. The user 
then receives the requested information. The user may now initiate another use case from 
the same view or may choose to close the view at 509. 

30 Figure 6 shows a form in which the view context may be passed. This figure illustrates 
the way in which the concept of a separate view context object that captures the complete 
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state of the view enables the data to be easily transferred and persisted in emerging data 
representation standards like XML. In this example the client receives XML data 601 and 
gives it an object representation in the form of a view context 603. This is useful because 
in object form the context has behavior associated with it and is more helpful to the 
5 application program. The message structure, on the other hand, assists in the transfer of 
the data and makes it possible to more easily convert the application into a web-based 
solution at a later date. 

Both the view context and the view may be represented in XML. In such a case the view 
10 may be created from data downloaded from the server. The client need not essentially be 
a browser. It may just as easily be a Java application. 

Figure 7 shows how the separation of the view and its context information into separate 
objects also assists in the flow of use cases with more than one handler and more than 
15 one thread. 

In a multi-threaded application, control often passes from one thread to another. For 
example, a first calling thread may post a request to a second worker thread to perform 
some task and then carry on with its own work. The worker thread, after completing the 

20 request, needs to hand control back to the first thread. This involves the transfer of 
control and the return of data to the calling thread from the worker thread. The 
representation of the view data in terms of contexts makes it easier to recreate the view 
with a new context. The view context can be easily passed across threads because the 
view response has also been abstracted away from the view through the use of the action 

25 information in the event which the view associates with the view context. In fact it 
becomes possible for the response itself to happen in a different thread. 

At the start of a use case the view 710 passes its newly created context or existing context 
720 to the handler of the use case 730. The use case handler 730 may then pass the view 
30 context 710 on to a second handler 740. In a threaded environment, the control would 
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immediately return to the calling handler 730 which then would pass control back to the 
view 710. The view then enters the usual event-processing loop. 

Once the second handler 740 has completed its task (in a second thread), it posts the reply 
5 back with the updated view context 720(U) and the view may be refreshed accordingly. 

In the absence of a view context object the view itself would have to be passed around 
and tracked. Passing the view to a different handler that is totally unrelated to the view 
makes the design extremely complicated and difficult to manage. 

10 

Figure 8 shows an example use case with more than one view and more than one handler. 
At step 800 the Customer handler receives notification that the user wishes to perform 
tasks related to maintaining customer details. This could take the form of a procedure 
MaintainCustomerDetails called on CustomerHandler. 

15 

In response, the Customer handler creates the Customer Details view, which is displayed 
to the user at step 801. The user, for example, may wish to edit a current account. The 
user selects the account and presses the edit button. The view passes the view context 
including the new data about the selected account and the associated event to the 
20 customer handler at 802. 

The Customer handler passes control along with the View Context to the Accounts 
handler at 803. The Accounts handler creates the Account Details View populated with 
the account to be edited at 804. After the fields have been edited, control passes back to 
25 the Accounts handler at 805. 

The Accounts handler uses a new thread and returns control to the Customer handler at 
806. At 807 the Account handler persists the changes on the server, which could be for 
example an IBM AS/400, by calling appropriate business logic methods in the business 
30 object still using the new thread. 



JP920000314US1 



10 



Meanwhile at 807' the original thread returns back to the event-processing loop from the 
Customer handler. 



At 808 the accounts handler finishes its work and transfers control of the new thread to 
5 the Customer handler. After this control transfer the two threads are re-synched and the 
new thread is returned to the pool while the original thread is used to refresh the 
Customer Details View of the modified account by executing the action part of the 
original event object. 

10 Figure 9 shows this same process for editing account details from the Customer Details 
View in a different format. Maintain Customer Details is called by the user on the 
Customer Details Handler at step 900. The Customer Details Handler creates the 
Customer Details View at 901 and displays it to the user. At 902 the user presses the edit 
account button on the Customer Details View. The Customer Details View associates the 

15 appropriate event with the View Context and passes the View Context to the Customer 
Details Handler at 903. The Customer Details Handler passes control to the Account 
Details Handler at 904, passing the View Context as an argument. 

At 905 the Accounts Details Handler creates the Account Details View and displays it to 
20 the user. The user makes the desired changes to the account and presses the OK button at 
906. The Account Details View notifies the Account Details Handler of this event and 
passes the View Context as an argument at 907. 

At this point a second thread is initiated to complete the task, and the original thread 
25 returns control to the Customer Details Handler at 908 which returns the Customer 
Details View to the UI event loop at 909. 

Meanwhile the second thread updates the account changes on the server database at 908' 
and returns at 909'. The second thread returns control to the Customer Details Handler at 
30 910' with the updated View Context. The Customer Details Handler instructs the 
Customer Details View to refresh itself at 911'. 
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The foregoing describes the invention including preferred forms thereof. Alterations and 
modifications as will be obvious to those skilled in the art are intended to be incorporated 
within the scope hereof, as defined by the accompanying claims. 



